/**
 * 全局样式
 */

/* 重置样式 */
* {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* 确保用户可以选择文本 */
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}

#app {
  width: 100%;
  height: 100%;
}

/* 滚动条样式 */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--n-scrollbar-track-color);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: var(--n-scrollbar-color);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--n-scrollbar-color-hover);
}

/* 通用工具类 */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.w-full {
  width: 100%;
}

.h-full {
  height: 100%;
}

.cursor-pointer {
  cursor: pointer;
}

.overflow-hidden {
  overflow: hidden;
}

.text-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 等级颜色类 - 使用更适合暗黑模式的颜色 */
.grade-1 {
  color: var(--grade-border-0);
}

.grade-2 {
  color: var(--grade-border-2);
}

.grade-3 {
  color: var(--grade-border-3);
}

.grade-4 {
  color: var(--grade-border-4);
}

.grade-5 {
  color: var(--grade-border-5);
}

.grade-6 {
  color: var(--grade-border-6);
}

/* 等级边框样式 - 直接使用border，简洁美观 */
.grade-bg-1 {
  border: 2px solid var(--grade-border-1);
}

.grade-bg-2 {
  border: 2px solid var(--grade-border-2);
}

.grade-bg-3 {
  border: 2px solid var(--grade-border-3);
}

.grade-bg-4 {
  border: 2px solid var(--grade-border-4);
}

.grade-bg-5 {
  border: 2px solid var(--grade-border-5); 
}

.grade-bg-6 {
  border: 2px solid var(--grade-border-6);
}

/* 等级边框悬停效果 - 简洁的强调效果 */
.ranking-item:hover .grade-bg-1,
.ranking-item:hover .grade-bg-2,
.ranking-item:hover .grade-bg-3,
.ranking-item:hover .grade-bg-4,
.ranking-item:hover .grade-bg-5,
.ranking-item:hover .grade-bg-6 {
  border-width: 3px;
  transform: scale(1.01);
}

/* 价格变化颜色类 */
.price-increase {
  color: #18a058;
}

.price-decrease {
  color: #d03050;
}

.price-stable {
  color: var(--n-text-color-3);
}

/* 动画类 */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.3s ease;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

.slide-up-enter-active,
.slide-up-leave-active {
  transition: all 0.3s ease;
}

.slide-up-enter-from {
  transform: translateY(20px);
  opacity: 0;
}

.slide-up-leave-to {
  transform: translateY(-20px);
  opacity: 0;
}

/* 响应式断点 */
@media (max-width: 768px) {
  .mobile-hidden {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .desktop-hidden {
    display: none !important;
  }
}

/* 打印样式 */
@media print {
  .no-print {
    display: none !important;
  }
  
  body {
    line-height: 1.4;
  }
  
  h1, h2, h3, h4, h5, h6 {
    page-break-after: avoid;
  }
  
  img {
    max-width: 100% !important;
  }
}

/* 无障碍支持 */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* 高对比度模式 */
@media (prefers-contrast: high) {
  .grade-1,
  .grade-2,
  .grade-3,
  .grade-4,
  .grade-5 {
    filter: contrast(1.5);
  }
}

/* 深色模式适配 */
@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: dark;
  }
}

/* 深色模式变量覆盖 */
html.dark {
  /* 自定义背景和文字变量 */
  --item-card-bg: var(--n-card-color);
  --item-text-primary: var(--n-text-color);
  --item-text-secondary: var(--n-text-color-2);
  --item-border-color: var(--n-border-color);
  --item-divider-color: var(--n-divider-color);

  /* 阴影适配深色模式 */
  --item-shadow-light: 0 2px 8px rgba(0, 0, 0, 0.3);
  --item-shadow-medium: 0 4px 12px rgba(0, 0, 0, 0.4);
  --item-shadow-heavy: 0 6px 16px rgba(0, 0, 0, 0.5);

  /* 价格变化背景色 */
  --price-up-bg: rgba(244, 67, 54, 0.1);
  --price-down-bg: rgba(76, 175, 80, 0.1);

  /* 悬停效果 */
  --item-hover-bg: rgba(255, 255, 255, 0.05);
}

/* 浅色模式变量 */
html:not(.dark) {
  /* 自定义背景和文字变量 */
  --item-card-bg: #ffffff;
  --item-text-primary: #333333;
  --item-text-secondary: #666666;
  --item-border-color: #e0e0e0;
  --item-divider-color: #e0e0e0;

  /* 阴影 */
  --item-shadow-light: 0 2px 8px rgba(0, 0, 0, 0.06);
  --item-shadow-medium: 0 4px 12px rgba(0, 0, 0, 0.08);
  --item-shadow-heavy: 0 6px 16px rgba(0, 0, 0, 0.1);

  /* 价格变化背景色 */
  --price-up-bg: #fff0f0;
  --price-down-bg: #e8f5e9;

  /* 悬停效果 */
  --item-hover-bg: rgba(0, 0, 0, 0.02);
}

/* 自定义属性 */
:root {
  --border-radius-small: 4px;
  --border-radius-medium: 8px;
  --border-radius-large: 12px;
  
  --spacing-xs: 4px;
  --spacing-sm: 8px;
  --spacing-md: 16px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  

  
  --z-index-dropdown: 1000;
  --z-index-modal: 2000;
  --z-index-notification: 3000;
  --z-index-tooltip: 4000;
}
/* 物品等级颜色系统 */
:root {
  /* 等级背景色 */
  --grade-bg-0: #949595;
  --grade-bg-1: #cdd5d5;
  --grade-bg-2: #188D14;
  --grade-bg-3: #658BCE;
  --grade-bg-4: #9b61c8;
  --grade-bg-5: #e8a64e;
  --grade-bg-6: #cb464a;

  /* 等级边框色 */
  --grade-border-0: #949595;
  --grade-border-1: #cdd5d5;
  --grade-border-2: #188D14;
  --grade-border-3: #658BCE;
  --grade-border-4: #9b61c8;
  --grade-border-5: #e8a64e;
  --grade-border-6: #cb464a;

  /* 等级标签色 */
  --grade-tag-0: #949595;
  --grade-tag-1: #cdd5d5;
  --grade-tag-2: #188D14;
  --grade-tag-3: #658BCE;
  --grade-tag-4: #9b61c8;
  --grade-tag-5: #e8a64e;
  --grade-tag-6: #cb464a;
} 